(19) Japanese Patent Office (JP) 
(12) Public Patent Disclosure Bulletin (A) 
(11) Public Patent Disclosure Bulletin No.: H08- 202626 
(43) Disclosure Bulletin Date: August 9, 1996 



(51) Int. CI. 

G 06 F 12/16 
GllC 16/06 
29/00 



Identification Code 
3 10 A 

301 A 



JPOFileNo. FI 
7623 - 5B 



Tech. Indie. 



GU C 17/00 309 F 
Request for Examination: NO, Claims: 2 (Total Pages: 7 ) 



(21) Patent Application No.: H07-013697 


(71) Applicant: 000000170 


Isuzu Motors Ltd. 


(22) Patent Application Date: January 31, 1995 


6-26-1 Minamiooi, 


Shinagawaku, Tokyo 




(72) Inventor: Toshibumi Koshizawa 




8 Tsuchidana, Fujisawa, 




Kanagawa Prefecture 




Isuzu Central Research (in-house) 




(74) Representative: Shuuji Moizumi, Attomey- 




at-Law 



(54) Title of the Invention: Memory ControUo: 
(57) Abstract 

[Purpose] In a memory controller that writes out data to an 
EEPROM, data that needs to be rewritten frequently over a 
. long period is stored correctly. 

[Construction] The data [in the CPU] is coii5)ared with the 
data aheady written to tiie same address of the EEPROM and 
if both are the same the processing stops, or flie frequency at 
which data is written out to the same address of the EEPROM 
is counted and stored in the EEPROM and, when the count 
value reaches the reload limit frequency, the address of the 
data is modified and written out. 



[Figure] 

Embodiment (H of the Invention 



Input Data 
■ Common Bus 



Claims 

Claim L A memory controller for writing out data to an EEPROM wherein said data is compared with 
data aheady written out to the same address of said EEPROM and, if both are the same, an update is 
blocked 

. Claim 2. A memory controller for writing out data to an EEPROM wherein the frequency at which said 
data is written out to the same address of said EEPROM is counted and stored in said EEPROM and, 
when said count value reaches the write-out limit frequency, the address of said data is modified and 
written out. 

Detailed Description of the Invention 
[0001] 

Industrial Field of Application 

This invention concerns a memory controller and, particularly, a memory controller used in electronic 
devices installed in vehicles. 
[0002] 
Prior Art 

In electronic devices for vehicles, learning control parameters, settings, etc. are checked in order to 
optimize their control, these are stored in a memory for reference in checking and servicing a failure code 
corresponding to tiie details of the system failure. 

[0003] . 1.. 1 

With such learning data and failure status codes, data needs to be stored, of course, when the vehicular 
electronic device is in operation and while the device is resting when the main power source is OFF. 
[0004] 

Because of this, conventionally, in order to realize the storing of learning data and failure status codes, at 

first a method utilizing a memory backup power source was adopted. 

[0005] 

In this method a RAM is installed in an electronic device and the main power source of the electromc 
device source provides a power source to this RAM from a separate system power source (backup power 
source). Even when the electronic device is resting (power source OFF) RAM data is stored by the 
supply to the backup power source. 
[0006] 

However, the mefliod utilizing such a memory backup power source has the following pitfeUs. 
[0007] 

1 . It is necessary to extend the wiring of the main power source to tiie backup power source m a separate 
system. 

2. As wiring for a backup power source normally brings about an application of power source voltage, 
in consideration of prevention of electrical accidents this wiring shpuld not be done. 

3 . Since the backup power supply is in direct contact witii the vehicular battery, if the battery is 
disconnected when there is inspection and servicing unrelated to inspection and servicing of 
electronic devices, the data in memory is erased. 

4. Since data in memory is erased when the body of an electronic device, even if restorable, is removed 
from a vehicle due to a failure, it is necessary to write down in a memo or whatever the contents of 
memory before removing the electronic device when taking the trouble to reproduce or confnrn a 
failure. 

[0008] 

Because of these things, in recent years a method using an EEPROM instead of a memory backup power 

source has become common. 

[0009] 

That is, by using an EEPROM known as an electrically erasable/writable non-volatile memory device, the 
data that needs to be stored is written -out to this EEPROM; this method of performing data storage has 
been used a lot. 



[0010] 

Problems the Invention Is To Solve 

However, in the method of using the EEPROM hke this there is the following problem. 
[0011] 

With the internal construction of the EEPROM, because the memory element gradually deteriorates due 
to erasing/writing-out data, the frequency of erase/write-out operations of data at the same address of the 
EEPROM is limited, so it is not suitable when it is necessary to write out data frequently. 
[0012] 

This point is a big problem in electronic devices for vehicles which require a comparatively long 

operational period and usable lifetime. 

[0013] 

Subsequently, this invention has the purpose whereby, in a memory controller that writes out data to an 
EEPROM, data that needs to be rewritten frequently over a long period is stored correctly. 
[0014] 

Means of Solving the Problems 

(1) In order to achieve the above aim, in the memory controller relating to this invention, data is 
compared with data already written out to the same address of an EEPROM and, if bofli are the same, 
an update is blocked. 

[0015] 

(2) And, in the invention, the frequency at which said data is written out to the same address of the 
EEPROM is counted and stored in said EEPROM and, when said count value reaches the write-out 
limit frequency, the address of said data is modified and written out 

[0016] 
Operation 

(1) In electronic devices, intemal data calculations are performed frequently and, when changes of data 
are few and the data calculated each time is nearly uniform, the data already written to EEPROM 
after data calculation is read once. Comparing ftis with the calculated data, only if both are different, 
the contents of the EEPROM already written are erased and the new data is written out. 

[0017] , 

(2) As state above, when data is calculated frequently and there are many changes of data, several 
EEPROM addresses are provided and, when writing out data regarding the same address, flie 
frequency is counted and this count is stored in the EEPROM. 

[0018] 

Also, when this count value exceeds the erase/write-out frequency stored in the EEPROM, by setting the 
address of the EEPROM anew, the same address cannot be used above a prescribed frequency. In this 
way the longevity of tiiie EEPROM is provided for. 
[0019] 

Embodiment 

Figure 1 shows an embodiment of the memory controller [2] relating to this invention and in the figure: 
[1] shows the CTU of the memory controller, [2] shows the EEPROM memory element, [3] shows the 
interface circuit for receiving data input, [4] shows the common bus providing data from the interface 
circuit [3] to the CPU [1] and the EEPROM [2]. 
[0020] 

Moreover, Figure 2 show the memory map of the EEPROM [2] for data read out according to the 
invention and here the data that is to be read out is devised as a 1-byte imit. Thus, as shown in fig. 2, only 
the address [ADD] for data write is necessary for the EEPROM [2] memory. 
[0021] 

Figure 3 shows a flow chart of the data write-in operation handled by tiie CPU [1] shown in Fig. 1 and 
this flow chart is operative when data is being written in. 



[0022] 

First, the CPU [1] calculates the data (A) to be written in (step S 1). 
[0023] 

Then, the contents (B) of the address [ADD] akeady stored in the EEPROM [2] are read out (step S2). 
[0024] 

Then, there is a comparison (step S3) of the data calculated in step SI with the memory contents of the 

EEPROM [2] read out in step S2. 

[0025] 

As a result, if A = B a write out of data is not necessary and the processing ends but, if A ?i B the data (A) 
calculated in step SI is written out to the EEPROM [2] and the contents of the address [ADD] are erased 
(step S4). 
[0026] 

So, tiie data (A) is written to the address [ADD] (step S5) and the processing is completed. 
[0027] 

By the process of the above steps SI ~ S5, generally the same value as the most recent data (A) can be 
stored in the EEPROM [2] but, in this case there is a modification of data and, since an erase/write-out is 
performed only when necessary, there is no adverse effect on the lifetime of the EEPROM. 
[0028] 

Figure 4 shows a flow chart of when data is read in by the CPU [1] by the EEPROM [2] and the data read 
reads the contents directly from the address [ADD] similar to the data read out (as in step S2) of an 
ordinary RAM (step SIO). 

[0029] , 
Figure 5 shows tiie embodiment of the memory controller (2) relating to tiie mvention and, adding to the 
embodiment of the invention shown in Fig. 1, it differs in that it has a 2-byte register [Rl] and a 1-byte 
register [R2] in the CPU [1]. A ROM [10] storing a prescribed frequency is included in the CPU [1] as 
well. 

[0030] . 
Figure 6 shows the memory map of the EEPROM [2] shown in Fig. 5; the offset value (pomt data) for 
showing the memory address and tiie address of tiie frequency count of the memory address' rarase/write- 
but in the address [ADD]. 
[0031] 

Fur&er, as shown in the figure, the memory for the data to be read out and the memory for the 

erase/write- out firequency count are allocated to tiie array X successively. 

[0032] 

Here the data to be written out is 1-byte, and 2-bytes is allocated for the erase/wnte-out frequency count 
as the maximum value of the erase/write-out frequency is 65,535. Thus, the write-out frequency count 
value is written to X(0), X(l) and X(3), X(4), ... and the data is written to addresses X(2), X(5), .... 
[0033] 

In Figure 7, first the data (A) to be written out is calculated (step Sll). 
[0034] 

Then, the erase/write-out frequency count value is read and loaded into the register [Rl] (step 812). hi 
tiiis case, as shown in the Fig. 6, as the count value is stored in all 2-bytes of the memoiy address whexe 
the data is written, flie count value is stored in flie addresses, X(0 + ADD) and X(l + ADD). 
[0036] 

Next, the count value of the register [Rl] and the set value are conqjared (step S13). 
[0037] 

This set value is previously stored in the ROM [10] built into the CPU [1] and, as mentioned above, it is 
set according to the erase/write-out frequencies guaranteed in the EEPROM [2]; in fliis embodiment for 2 
byte data this could be set to a maximum of 65,535 times, this is not to say that when this frequency is 
guaranteed above 65, 535 times, it could not be modified to set 3-bytes of memory and so forth for the 
count. 



[0038] 

As a result of comparison in step SI 3, when the contents of the register [Rl] is less than the set value, 

since the count value and data can be written out to memory at the same address as the erase/write-out of 

the count and data together has been done up to now, "1" is added to the presoit erase/write-out frequency 

and this result remains in the register [Rl] (step S 14). 

[0039] ■ " 

Then, to write in flie next count value, the contents of addresses, X(0 + ADD) and X(l + ADD), are 

erased (step SIS). 
[0040] 

Next, the contents of the register [Rl] are written to the addresses, X(0 + ADD) and X(l + ADD), (step 
S16), to write out flie data (A) the contents of the memory address for data storage, X(2 + ADD), are 
erased (step S17), the data (A) is written to the address, X(2 + ADD), (step SI 8), and the process is 
completed. 
[0041] 

On the other hand, in step S13, when it is determined that the contents of the register [Rl] reach the set 
value, the operations of steps S19 ~ S23 are carried out to modify the addresses of the memory for data 
and the memory for the count. 

[0042] . rr,^-, 

First, in step S19, the offset of the address [ADD], the address point, is transfenred to the register [R2]. 

[0043] ^ 
Then, to write out the offset in step SI 1, the offset value of the address [ADD] is erased, "3" is added to 
the address [ADD] presently transferred to the regista- [R2] and tiie result of this remains in the register 
[R2] (step S21). 
[0044] 

Li step S22 tiie value of that register [R2] is written to the address [ADD] as a new address offset value; 
fiirther, as it is the first data write-out to a new address, "1" is written to the register [Rl] as the 
erase/write-out frequency count (step S23). 
[0045] 

After this, jumping to step S15, the same operations as above (steps S15 ~ S18) are earned out and flie 
- process stops. 
[0046] 

Thus, by executing the operations of steps S19 ~ S23, just "3" is added to the current pomt value (offset 
of address [ADD]). As the count value address and data address on the memory map of the EEPROM [2] 
shown in Fig. 6 are respectively modified by "3", a new address is set. 
[0047] 

Further, since the address point value (contents of address [ADD]) and erase/write-out frequency count 
value (address X(0 + ADD), X(l + ADD)) together with the data value (address X(2 + ADD)) are stored 
in the EEPROM [2], even when the main power source of liie electronic device is OFF, the erase/write- 
out frequency is counted accurately in 4e EEPROM [2] and. the process ends without the disappearance 
of the stored data. 

[0048] . 

Figure 8 shows a flow chart of the read-out of the data value written by the operation shown m Fig. 7 and 
in reading the memory contents of the address, X(2 + ADD), the stored data value can be read (step 830). 
[0049] 

In the memory map shown in Fig. 6 and the flow chart shown in Fig. 7, the address on the memory map 
of the address offset of the address [ADD] is fixed at the first place but, as it is set in the EEPROM, there 
is a limit on the erase/write-out frequency similarly to the data and it can be modified in flie same way as 
the data address is modified. 



[0050] 

Effect of the Invention 

With the memory controller of the invention, as described above, because of a constitution whereby 
when, comparing data with data akeady written to the same address of an EEPROM, both are the same, 
processing stops and when, after storing in the EEPROM the data of the frequency count of erase/write- 
outs to the same address of the EEPROM, said count value reaches the write-out frequency limit, it is 
written out to a modified data address, a backup power source is not necessary and, additionally, data that 
needs to be written out frequently can be stored accurately for the long term. Li particular, learning data 
and feilure status codes can be stored without a backup power source in electronic devices for 
commercially produced vehicles. 
A Brief Description of the Figures 

Figure 1 is a block diagram showing the embodiment of the memory controllo: (1) relating to this 
invention. 

Figure 2 is a memory map of the EEPROM used in the memoiy controller (2) relating to the invention. 
Figure 3 is a flow chart of the data write operation carried out by the CPU in the memory controller (1) 
relating to the invention. 

Figure 4 is a flow chart of the data read operation carried out by the CPU in the memory controller (1) 
relating to the invention. 

Figure 5 is a block diagram showing an embodiment of the memory controller (2) relating to the 
invention. 

Figure 6 is memory map of the EEPROM used in tiie memory controller (2) relating to the invention. 
Figure 7 is a flow chart of the data write operation carried out by the CPU in the memory controller (2) 
relating to the invention. 

Figure 8 is a flow chart of the data read operation carried out by the CPU in the memory controller (2) 
relating to the invention. 
Explanation of Reference Numbers 

1 CPU 

2 EEPROM ^ 
10 ROM 
R1,R2 Registers 

In the figures, the same reference numbers show the same or related parts. 

[Figure 1] Embodiment (1) of the Invention 

3 Input Data 

4 CommonBus 

[Figure 2] EEPROM Memory Map 
Address [ADD] 1 -byte 

[Figures] Flow Chart ofData Write Operation 

5 I Calculate data (A) to be written 

52 Read contents OB) in memory at address [ADD] 

53 Compare A arid B 

54 Erase contents of address [ADD] 

55 Write out data (A) to be written to address [ADD] 

[Figure 4] Flow Oiart ofData Read Operation 

S 10 Read the contents of memory at address [ADD] 

[Figures] Embodiment (2) of the Invention 
1 Rl register 
R2 register 
' 3 Input data 
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4 Common Bus 

[Figure 6] EEPROM Memory Map 
Address [ADD] Address offset value (1-byte) 

Write-out frequency count (2-byte) 

Data (1-byte) 

Write-out frequency count (2-byte) 
Data (1-byte) 

[Figure 8] Flow Chart of Data Read Operation 

S30 Read the memory contents of flie address, X(2 + ADD) 

[Figure?] Flowchart of Data Write Operation 

5 1 1 Calculate data (A) to be written 

5 12 Read 1 write-out frequency count to register R 

5 13 Contents of regist^ Rl 

[left branch] < set value 

5 15 Erase contents of addresses, X(0 + ADD), X(l + ADD) 

516 Write contents of register R! to addresses, X(0 + ADD), X(l + ADD) 

5 1 7 Erase contents of address, (2 + ADD) 

5 1 8 Write data (A) to be written to address, (2 + ADD) 

[right branch] = set value 

5 1 9 Contents of address [ADD] R2 

520 Erase contents of address [ADD] 

S22 Write contents of R2 to address [ADD] 



